IDL_Variable

The IDL_Variable class contains static methods that are available for all IDL variables except objects and structures.

Attributes

All IDL variables have special attributes that return information about the variable:

var.dim An array giving the dimensions (0 for scalars).
var.length The number of elements in the variable.
var.ndim An integer giving the number of dimensions (0 for scalars).
var.tname A string giving the raw IDL type name. For structures this returns "STRUCT", while for objects this returns "OBJREF".
var.typecode An integer giving the IDL type code.

var.typename

A string giving the IDL type name. For structures and objects this returns the actual structure or class name.

See Variable Attributes for more details.

Superclasses

None

IDL_Variable

IDL_Variable::Compare

IDL_Variable::Compare compares one variable to another and return –1 if the value is smaller, 0 if the values are equal, or +1 if the value is larger.

Note: The Compare method uses the same rules as the relational operators (LT, GT, etc.) when comparing values. For example, for strings, the method walks through each character of the two strings until it finds a difference in the byte values. For complex numbers, the absolute value is used for the comparison.

Note: If the two variables are different types, the values will be promoted to the larger type using IDL's standard rules of type promotion.

Note: You can not use the Compare method with pointers.

Tip: The Compare method is useful when constructing comparison functions for IDL_Variable::Sort.

Examples

Compare one string to another:

a = "cap"

PRINT, a.Compare("cat")

IDL prints:

-1

Compare an array variable with a scalar:

a = [10,3,7,5,11]

PRINT, a.Compare(5)

IDL prints:

1 -1  1  0  1

Syntax

Result = var.Compare( Arg )

Return Value

The result is always a variable of type INT containing the values –1, 0, or +1. If both var and Arg are scalars then the result is an integer scalar. If one of the arguments is a scalar and the other is an array, then the scalar is matched up against each value of the array and the result is an integer array of the same dimensions. If both arguments are arrays then the result is an integer array with dimensions equal to whichever array has the smaller number of elements.

Arguments

Arg

The variable to compare against.

Keywords

None

IDL_Variable::Convert

The IDL_Variable::Convert method converts the variable to a different data type. This method is equivalent to calling the FIX function with the appropriate TYPE keyword value.

Examples

Convert a float array to an integer array:

var = FINDGEN(5)

; We could also use TYPE=3 instead of /LONG

newvar = var.Convert(/LONG)

HELP, newvar

IDL prints:

NEWVAR LONG = Array[5]

Now convert a string array to double-precision floats:

var = ['3.14', '1.23', '-1d100']

newvar = var.Convert(/DOUBLE)

PRINT, newvar

IDL prints:

3.1400000 1.2300000 -1.0000000e+100

Syntax

Result = var.Convert( KEYWORD=keyword )

Return Value

The result is a scalar or array of the same dimensions as the variable with each element converted to the new data type.

Arguments

None.

Keywords

You must specify either the TYPE keyword or one of the individual type keywords.

TYPE

Set this keyword to an integer giving the IDL type code to convert to. Possible values are:

BYTE, INT, LONG, FLOAT, DOUBLE, COMPLEX, STRING, DCOMPLEX, UINT, ULONG, L64, UL64

Instead of using the TYPE keyword, you can set one of these keywords to convert your variable to that type.

IDL_Variable::Diff

IDL_Variable::Diff returns the number of unique elements which have been added or removed from a variable. The actual values can be captured with output keywords.

Examples

Imagine we have a list of files:

file_list = ['file_1.dat','file_2.dat','/processed/file.dat']

Sometime later, we want to find out if our list of files has changed:

file_list_new = ['file_2.dat','file_3.dat', $

'/processed/file.dat','/processed/file_1.dat']

count = file_list.Diff( file_list_new, ADDED=add, REMOVED=remove )

The value for count, add, and remove are:

PRINT, /IMPLIED, count, add, remove

IDL prints:

3

 

file_3.dat

/processed/file_1.dat

 

file_1.dat

Syntax

Result = var.Diff( Arg, ADDED=variable, REMOVED=variable, NADDED=variable, NREMOVED=variable)

Return Value

The result is a scalar value representing the number of unique elements which have changed (i.e., the sum of NADDED and NREMOVED).

Arguments

Arg

The comparison array.

Keywords

ADDED

A named variable that will contain the values which are present in Arg but not in the variable.

NADDED

A named variable that will contain the number of values in ADDED.

REMOVED

A named variable that will contain the values which are present in the variable but not in Arg.

NREMOVED

A named variable that will contain the number of values in REMOVED.

IDL_Variable::Dup

The IDL_Variable::Dup method duplicates a scalar value and returns an array with the given dimensions. This is equivalent to the REPLICATE function, except for inputs of type string, where the ::Dup method joins together the strings across the first dimension.

Examples

IDL> a = 1.23

IDL> b = a.Dup(5,2)

IDL> b.dim

5    2

IDL> print, b

1.23000 1.23000 1.23000 1.23000 1.23000

1.23000 1.23000 1.23000 1.23000 1.23000

 

IDL> a = '*'

IDL> print, a.Dup(10)

**********

 

IDL> b = a.Dup([6,5,2])

IDL> b.dim

5    2

IDL> print, b

****** ****** ****** ****** ******

****** ****** ****** ****** ******

 

Syntax

Result = var.Dup( Dim )

Return Value

Returns an array of the given dimensions, with the same type as var. If var is type string then the result is a string array of one less dimension than Dim, where Dim[0] indicates the number of copies of var in each element.

Arguments

Dim

A scalar expression or a vector of up to eight elements containing the dimensions of the result.

Keywords

None

IDL_Variable::Equals

The IDL_Variable::Equals method returns 1 (true) if the variable is equal to the supplied input argument. The ::Equals method uses the same rules as the ARRAY_EQUAL function:

For all cases, if the data types are different, then the ::Equals method does automatic type promotion before comparing the values.

Examples

Compare two arrays of different data types:

var1 = [1.0, 2.0, 3.0, 4.0]

var2 = [1, 2, 3, 4]

PRINT, var1.Equals(var2)

IDL prints:

1

Compare an array and a scalar:

var = STRARR(100)

PRINT, var.Equals("")

IDL prints:

1

Syntax

Result = var.Equals(Value, TOLERANCE=value )

Return Value

A boolean value of 0 (false) or 1 (true).

Arguments

Value

An IDL variable to compare to var.

Tip: If you are comparing an array to a scalar, you should make sure that the scalar has the same data type as the array. If the scalar is a more precise data type, then ::Equals will convert the entire array to that type before doing the comparison.

Keywords

TOLERANCE

By default, ::Equals will return true if the corresponding elements in each operand are exactly equal. Set the TOLERANCE keyword to a non-zero number to instead treat values as being equal if they are within the tolerance value from each other. If the type of the tolerance variable is not the same as the input arguments, it will be converted to the appropriate type. For each pair of elements, Xi and Yi, the pair is considered equal if |XiYi| <= |T|, where |T| is the absolute value of the tolerance.

Note: The TOLERANCE keyword is not allowed for input arguments of type string, pointer reference, or object reference.

Note: Setting TOLERANCE=0 is the same as not specifying the keyword.

IDL_Variable::Filter

The IDL_Variable::Filter method passes each data value through a boolean filter function or Lambda function and returns only values that pass the test.

Examples

Create a new file called myfilterfunction.pro that keeps only prime numbers:

function myfilterfunction, value

return, value le 3 || MIN(value mod [2:FIX(SQRT(value))])

end

Use your function to return only the prime numbers in an array:

var = [2:50]

newvar = var.Filter('myfilterfunction')

PRINT, newvar

IDL prints:

2 3 5 7 11 13 17 19 23 29 31 37 41 43 47

Now use a Lambda function to avoid creating a separate routine:

var = [2:50]

newvar = var.Filter(Lambda(n:n le 3 || MIN(n mod [2:FIX(SQRT(n))])))

Tip: The COMPILE_CODE procedure can be used to generate functions on the fly.

Syntax

Result = var.Filter( Function, Args , /VECTOR )

Return Value

The result is a vector of the same type as the input containing only the values where the filter function returned a non-zero number for that input value. If none of the values are good then the method returns !NULL.

Arguments

Function

A string or Lambda expression giving the name of the user-defined function to call for each value. For user-defined functions, your function should have the form:

function myfunction, value

result = ...

return, result

end

The result should be a scalar value containing a non-zero value if the input value "passes" your filter test, and a zero value if the input value "fails" your filter test.

Args

You can specify any number of additional arguments to be passed on to your filter or Lambda function. Each argument must be either a scalar or an array of the same length as your input. For scalar arguments, ::Filter will pass in that same scalar value to each call of the filter function. For vector arguments, ::Filter will pull out the value corresponding to the current input value and pass that into your filter function as a scalar.

Keywords

VECTOR

Set this keyword if your Function is "vectorized". In other words, it will give the same result if all of the values are passed in at once instead of looping over each value. By default, IDL will pass in each value as a separate call.

IDL_Variable::Finite

The IDL_Variable::Finite method returns an array containing only the finite values within the variable. A value is finite if it is not equal to NaN (not-a-number) or infinity.

This method is equivalent to calling var[WHERE(FINITE(var), /NULL)].

Note: If the input variable is type integer or string then the method returns the original variable.

Examples

var = FINDGEN(10, 20)

newvar = var.Finite( )

HELP, newvar

 

; Now make some values be non-finite.

var[[5, 10, 15, 20]] = !VALUES.F_NaN

newvar = var.Finite( )

HELP, newvar

IDL prints:

NEWVAR FLOAT = Array[10, 20]

NEWVAR FLOAT = Array[196]

Syntax

Result = var.Finite( )

Return Value

If every element of the input variable is finite, then the result is an array of the same type and dimensions as the input. If the input contains any non-finite elements, then the result is a one-dimensional array (a vector) containing only the finite values.

If none of the values are finite then the result is set to !NULL.

Arguments

None.

Keywords

None.

IDL_Variable::FromBits

The IDL_Variable::FromBits method converts a variable from its bit representation to a scalar value or an array of values.

Example

var = "IDL"

newvar = var.ToBits()

HELP, newvar

var1 = newvar.FromBits(/BYTE)

var2 = newvar.FromBits(/STRING)

PRINT, var1, var2

IDL prints:

NEWVAR BYTE = Array[8, 3]

73  68  76

IDL

Syntax

Result = var.FromBits( )

Return Value

Assume that the input variable has dimensions [N, D1, D2, ...], where N is the number of bits per element (usually a multiple of 8) and [D1, D2, ...] are the additional dimensions. The result is then an array of dimensions [D1, D2, ...].

If the input variable is just a vector of length N then the result is a scalar.

By default the result will have type LONG, unless one of the type keywords is set.

Arguments

None.

Keywords

You can specify either the TYPE keyword or one of the individual type keywords. If you do not set any keywords then type LONG is used.

TYPE

Set this keyword to an integer giving the IDL type code of the result. Possible values are:

BYTE, INT, LONG, FLOAT, DOUBLE, STRING, UINT, ULONG, L64, UL64

Instead of using the TYPE keyword, you can set one of these keywords to return a variable of that type.

IDL_Variable::Hashcode

The IDL_Variable::Hashcode method returns an unsigned integer (32-bit) hash code for the variable's value. The hash code is computed using Bob Jenkins' One-At-A-Time hash, downloaded from http://www.burtleburtle.net/bob/hash/doobs.html.

The hash code computation has the following properties:

Examples

var1 = "abcd"

var2 = "dcba"

PRINT, var1.Hashcode( )

PRINT, var2.Hashcode( )

IDL prints:

3448463878

1944347701

Syntax

Result = var.Hashcode( )

Return Value

An unsigned long integer.

Arguments

None.

Keywords

None.

IDL_Variable::HasValue

The IDL_Variable::HasValue method determines whether the array contains a given value or values.

Examples

Determine whether a string array contains a specific set of values:

str = ['3', '1', '2', '5', '4']

PRINT, str.HasValue([1,2,3])

IDL prints:

1

Syntax

Result = var.HasValue( Value )

Return Value

A boolean value of 1 (true) or 0 (false). If the Value argument is an array, each of its values must be contained within var for the result to be true.

Arguments

Value

A scalar or array of any IDL data type except objects or structures.

Tip: You should make sure that Value has the same data type as the variable var. Otherwise, if the Value is a more precise data type, then ::HasValue will convert the entire var array to that type before doing the comparison.

Keywords

None.

IDL_Variable::IsFinite

The IDL_Variable::IsFinite method returns 1 (true) if every element of a variable is finite or 0 (false) if any element is NaN or Infinity.

Examples

var1 = [1.0, 2.0, 3.0]

var2 = [1.0, !VALUES.F_NaN, 3.0]

PRINT, var1.IsFinite( ), var2.IsFinite( )

IDL prints:

1  0

Syntax

Result = var.IsFinite( )

Return Value

A boolean value of 0 (false) or 1 (true).

Arguments

None.

Keywords

None.

IDL_Variable::IsInfinite

The IDL_Variable::IsInfinite method returns 1 (true) if every element of the variable is equal to Infinity or 0 (false) if any element is finite.

Examples

var1 = !VALUES.D_Infinity

var2 = [1, 2, 3, !VALUES.F_Infinity]

PRINT, var1.IsInfinite( ), var2.IsInfinite( )

IDL prints:

1  0

Syntax

Result = var.IsInfinite( )

Return Value

A boolean value of 0 (false) or 1 (true).

Arguments

None.

Keywords

None.

IDL_Variable::IsNaN

The IDL_Variable::IsNaN method returns 1 (true) if every element of the variable is equal to NaN or 0 (false) if any element is finite.

Examples

var1 = !VALUES.F_NaN

var2 = [!VALUES.F_NaN, !VALUES.F_NaN, 1.23, !VALUES.F_NaN]

PRINT, var1.IsNaN( ), var2.IsNaN( )

IDL prints:

1  0

Syntax

Result = var.IsNaN( )

Return Value

A boolean value of 0 (false) or 1 (true).

Arguments

None.

Keywords

None.

IDL_Variable::IsReal

The IDL_Variable::IsReal method returns 1 (true) if every element of the variable has a zero imaginary part.

Note: For non-complex data, ::IsReal will return 1 (true), without examining any of the data. For complex and double-complex data, each element is examined. If all of the elements have zero imaginary, then 1 (true) is returned. As soon as an element is reached that has a non-zero imaginary part, then 0 (false) is returned.

Examples

var1 = 255b

var2 = [dcomplex(1, 0), dcomplex(2, 0)]

var3 = [dcomplex(1, 0), dcomplex(2, 1)]

PRINT, var1.IsReal(), var2.IsReal(), var3.IsReal()

IDL prints:

1  1  0

Syntax

Result = var.IsReal( )

Return Value

A boolean value of 1 (true) or 0 (false).

Arguments

None.

Keywords

None.

IDL_Variable::Map

The IDL_Variable::Map method passes each data value through a user-defined function or Lambda function.

Examples

Create a new file called mymapfunction.pro that returns a cubic polynomial:

function mymapfunction, x, a, b, c

return, (x - a)^3.0 + (x - b)^2 + (x - c)

end

Use your function to map an array to the new values:

var = [-2: 2: 0.01]

 

; Each var value is passed in separately

newvar = var.Map('mymapfunction', 1, 2, 0)

PRINT, var, newvar

IDL prints:

-2.00000 -1.99000 -1.98000 -1.97000 -1.96000 ...

-13.0000 -12.8008 -12.6032 -12.4072 -12.2127 ...

Now use a Lambda function to avoid creating a separate routine:

var = [-2: 2: 0.01]

 

; Each var value is passed in separately

newvar = var.Map(Lambda(x,a,b,c:(x-a)^3.0+(x-b)^2+(x-c)), 1, 2, 0)

This function is actually vectorizable, so we can use /VECTOR:

var = [-2: 2: 0.01]

lcubic = Lambda(x,a,b,c:(x-a)^3.0+(x-b)^2+(x-c))

 

; All of the var values are pass in at once.

newvar = var.Map(lcubic, 1, 2, 0, /VECTOR)

Tip: The COMPILE_CODE procedure can be used to generate functions on the fly.

Syntax

Result = var.Map( Function, Args , /VECTOR )

Return Value

If the user-defined function returns scalars, then the result is a variable of the same dimensions as the input. If the user-defined function returns an array, then the result is a variable with the combined dimensions of the function's result and the original input.

The data type of the result is determined by the first call to the Function.

Arguments

Function

A string or Lambda expression giving the name of the user-defined function to call for each value. For user-defined functions, your function should have the form:

function myfunction, value

result = ...

return, result

end

The result should be a scalar value.

Args

You can specify any number of additional arguments to be passed on to your user-defined function or Lambda function. Each argument must be either a scalar or an array of the same length as your input. For scalar arguments, ::Map will pass in that same scalar value to each call of the function. For vector arguments, ::Map will pull out the value corresponding to the current input value and pass that into your function as a scalar.

Keywords

VECTOR

Set this keyword if your Function is "vectorized". In other words, it will give the same result if all of the values are passed in at once instead of looping over each value. By default, IDL will pass in each value as a separate call.

More Examples

Construct a mapping that returns a three-element array for each input value containing the original value along with the sine and cosine:

a = [1:100]

r = a.Map(Lambda(a: [a, sin(a), cos(a)]))

HELP, r

IDL prints:

R FLOAT = Array[3, 100]

We could also return the result as a structure array with three fields:

a = [1:100]

r = a.Map(Lambda(a: {Data: a, SinA: sin(a), CosA: cos(a)}))

HELP, r

HELP, r.A, r.SINA, r.COSA

IDL prints:

R STRUCT = -> <Anonymous> Array[100]

<Expression> INT = Array[100]

<Expression> FLOAT = Array[100]

<Expression> FLOAT = Array[100]

IDL_Variable::NestedMap

The IDL_Variable::NestedMap method passes each array value along with up to eight other arguments through a user-defined function or Lambda function. Each array value is combined with every element from the other arguments using a nested loop. This operation also goes by the name "list comprehension" or "Cartesian product". You can also supply an optional filter function to remove unwanted results.

Difference between Map and NestedMap

Assume we have two arrays, a and b, with three elements each. For a given map function F(a,b):

a.Map(F, b) returns a vector containing:

[F(a[0], b[0]), F(a[1], b[1]), F(a[2], b[2])]

a.NestedMap(F, b) returns a 2D array containing:

[[ F(a[0], b[0]), F(a[1], b[0]), F(a[2], b[0]) ],

 [ F(a[0], b[1]), F(a[1], b[1]), F(a[2], b[1]) ],

 [ F(a[0], b[2]), F(a[1], b[2]), F(a[2], b[2]) ]]

Example

Return a new array containing every combination of items from two array:

a = ['a', 'b', 'c']

b = ['d', 'e', 'f']

c = a.NestedMap(Lambda(x,y:x+y), b)

HELP, c

PRINT, c

IDL prints:

C STRING = Array[3, 3]

  ad  bd  cd

  ae  be  ce

  af  bf  cf

Syntax

Result = var.NestedMap( Function, Args , FILTER=string)

Return Value

The result is an array containing the new values. The data type of the result is determined by the first call to the Function.

If FILTER is not supplied then the result is a multi-dimensional array, with each dimension given by the number of elements of var and each additional argument. For example, if var has 10 elements, argument 1 has 7 elements, and argument 2 has 4 elements, then the result is a [10, 7, 4] array.

If FILTER is supplied then the result is a vector containing all of the retained results. Note that even if all of the results survive the filter, the result will still be a vector.

Arguments

Function

A string or Lambda expression giving the name of the user-defined function to call for each value. For user-defined functions, your function should have the form:

function myfunction, value, arg1, arg2, ...

result = ...

return, result

end

Args

You can specify up to eight additional arguments. Each argument must be either a scalar, array, or list of any length. For scalar arguments, ::NestedMap will pass in that same scalar value to each call of the function. For vector arguments, ::NestedMap will perform a nested loop over all elements of that argument plus all other arguments. The nested loop is performed from left to right across the arguments, starting with the original var variable.

Keywords

FILTER

Set this keyword to a string or Lambda expression giving the name of a user-defined filter function. The function should have the form:

function myfilter, result

good = some function of result...

return, good ? 1 : 0

end

This function will be called for each result value. The function should return 1 (true) if the result should be added to the Result array, 0 (false) if the result should be discarded, or –1 if the NestedMap should stop early and return just the results up to (but not including) that result.

More Examples

Use a Lambda function to return triangles that satisfy the Pythagorean theorem. First construct a new array containing triplets of all combinations of numbers between 1 and 20:

x = [1:20]

p = x.NestedMap(Lambda(x,y,z:[x,y,z]), x, x)

HELP, p

IDL prints:

P INT = Array[3, 20, 20, 20]

This is not what we want. We need to keep only triplets that satisfy x^2 + y^2 = z^2. Use the FILTER keyword to keep only these values:

p = x.NestedMap(Lambda(x,y,z:[x,y,z]), x, x, $

 FILTER=Lambda(r:r[2]^2 eq r[0]^2+r[1]^2))

HELP, p

PRINT, p[*, 0:1] ; print the first two triplets

IDL prints:

P INT = Array[3, 12]

4   3   5

3   4   5

This still isn't what we want because it has duplicate triplets. Change the filter function to exclude duplicates:

p = x.NestedMap(Lambda(x,y,z:[x,y,z]), x, x, $

FILTER=Lambda(r:(r[0] le r[1]) && (r[2]^2 eq r[0]^2+r[1]^2)))

HELP, p

PRINT, p

IDL prints:

P INT = Array[3, 6]

3    4    5

6    8   10

5   12   13

9   12   15

8   15   17

12  16   20

Tip: The COMPILE_CODE procedure can be used to generate functions on the fly.

IDL_Variable::PtrValid

The IDL_Variable::PtrValid method returns the validity of its pointer arguments.

Examples

var = PTR_NEW(228l)

PRINT, var.PtrValid( )

IDL prints:

1

Syntax

Result = var.PtrValid( )

Return Value

A boolean value of 0 (false) or 1 (true). If var is not of type pointer, then 0 is returned. If var is an array then ::PtrValid returns an array of 0's and 1's.

Arguments

None.

Keywords

None.

IDL_Variable::Reduce

The IDL_Variable::Reduce method passes each data value cumulatively from left to right through a user-defined function or Lambda function and returns a single result.

Examples

Create a new file called myreducefunction.pro that adds up arrays (or concatenates strings):

function myreducefunction, accumvalue, value

return, accumvalue + value

end

Use your function on an integer array and a string array:

var = [1:100]

newvar = var.Reduce('myreducefunction')

PRINT, newvar

var = ['a','b','r','a','c','a','d','a','b','r','a']

newvar = var.Reduce('myreducefunction')

PRINT, newvar

IDL prints:

5050

abracadabra

Now use a Lambda function to avoid creating a separate routine:

var = ['a','b','r','a','c','a','d','a','b','r','a']

newvar = var.Reduce(Lambda(x,y:x+y))

Finally, use the /CUMULATIVE to return all of the intermediate results:

newvar = var.Reduce(Lambda(x,y:x+y), /CUMULATIVE, VALUE="IDL: ")

PRINT, newvar

IDL prints:

IDL: a

IDL: ab

IDL: abr

IDL: abra

IDL: abrac

IDL: abraca

IDL: abracad

IDL: abracada

IDL: abracadab

IDL: abracadabr

IDL: abracadabra

Tip: The COMPILE_CODE procedure can be used to generate functions on the fly.

Syntax

Result = var.Reduce( Function, Args, /CUMULATIVE, VALUE=value)

Return Value

The result is a value containing the cumulative result. The data type and dimensions of the result will depend upon your calling function's result type and dimensions.

If your input contains a single element then this value will be returned as the result without calling the function, unless the VALUE keyword is set, in which case the function will be called once.

Tip: You can use the /CUMULATIVE keyword to return all of the intermediate results instead of just the final result.

Arguments

Function

A string or Lambda expression giving the name of the user-defined function to call for each value. For user-defined functions, your function should have the form:

function myfunction, accumvalue, value

result = ...

return, result

end

The result should be a scalar value that combines the current accumulated value (the first argument) and the current input value (the second argument).

Args

You can specify any number of additional arguments to be passed on to your user-defined function or Lambda function. Each argument must be either a scalar or an array of the same length as your input. For scalar arguments, ::Reduce will pass in that same scalar value to each call of the filter function. For vector arguments, ::Reduce will pull out the value corresponding to the current input value and pass that into your function as a scalar.

Keywords

CUMULATIVE

If this keyword is set, then the Result will be a vector containing all of the intermediate cumulative results instead of just the final result.

VALUE

Set this keyword to the starting value. If this keyword is set then this value will be passed into your function along with the first element of your input. If this keyword is not set then the first two elements will be passed into your function.

IDL_Variable::Reform

The IDL_Variable::Reform method changes the dimensions of an array without changing the total number of elements.

This method is equivalent to calling the REFORM function.

Examples

var = FINDGEN(100)

 

; This is equivalent to var.Reform([5, 20])

newvar = var.Reform(5, 20)

HELP, newvar

IDL prints:

NEWVAR FLOAT = Array[5, 20]

Now remove a leading dimension of 1, replacing the original variable:

var = FLTARR(1, 20)

var = var.Reform(/OVERWRITE)

HELP, var

IDL prints:

VAR FLOAT = Array[20]

Syntax

Result = var.Reform( /OVERWRITE )

or

Result = var.Reform( Dimensions, /OVERWRITE )

or

Result = var.Reform( Dim1, Dim2, Dim3, ..., /OVERWRITE )

Return Value

An array of the specified dimensions.

Arguments

If the Reform method is called with no arguments, then the method removes any dimensions of length 1 and returns.

You can specify the result dimensions as either a single argument containing a vector of dimensions, or as separate arguments, one for each dimension.

Dimensions

Set this argument to a vector containing the new dimensions. The total number of elements must be the same as the original variable.

Dim1

Set the Dim1, Dim2, ... arguments to integers giving the size of each dimension. The total number of elements must be the same as the original variable.

Keywords

OVERWRITE

Set this keyword to change the dimensions of the variable "in place" instead of making a copy.

Tip: For the OVERWRITE keyword to be effective, use the same name for the result variable as the input variable. For example:

myvar = FINDGEN(100)

myvar = myvar.Reform(10, 10, /OVERWRITE)

IDL_Variable::Shift

The IDL_Variable::Shift method shifts elements of vectors or arrays along any dimension by any number of elements. Positive shifts are to the right while negative shifts are to the left. All shifts are circular: Elements shifted off one end wrap around and are shifted onto the other end.

This method is equivalent to calling the SHIFT function.

Example

Take a two-dimensional array, and shift the columns 2 spaces to the left, and the rows down by 1.

var = BINDGEN(10, 5)

PRINT, var

PRINT, var.Shift(-2, 1)

; we could also have done var.Shift([-2, 1])

IDL prints:

 0  1  2  3  4  5  6  7  8  9

10 11 12 13 14 15 16 17 18 19

20 21 22 23 24 25 26 27 28 29

30 31 32 33 34 35 36 37 38 39

40 41 42 43 44 45 46 47 48 49

 

42 43 44 45 46 47 48 49 40 41

 2  3  4  5  6  7  8  9  0  1

12 13 14 15 16 17 18 19 10 11

22 23 24 25 26 27 28 29 20 21

32 33 34 35 36 37 38 39 30 31

Syntax

Result = var.Shift( S1, S2, S3, ... )

Return Value

An array of the same dimensions as the variable.

Arguments

S1, S2, S3, ...

The shift parameters. The Si arguments can be either a vector containing the shift parameters for each dimension, or a sequence of up to eight scalar shift values.

A shift specification of 0 means that no shift is to be performed along that dimension.

Keywords

None.

IDL_Variable::Sort

The IDL_Variable::Sort method returns a sorted copy of the input array using either IDL's built-in comparison rules or a user-defined compare function.

This method is equivalent to calling var[SORT(var)].

Note: String arrays are sorted using the ASCII collating sequence. Complex arrays are sorted by their magnitude. Array values which are NaN (not-a-number) are moved to the end of the result.

Example

var = [0.7, 0.2, 0.4, 0.9, 0.0]

newvar = var.Sort( )

PRINT, newvar

IDL prints:

0.000000 0.200000 0.400000 0.700000 0.900000

Syntax

Result = var.Sort( [COMPARE_FUNCTION=string] [, COUNT=integer] [, INDICES=variable] [, /REVERSE] )

Return Value

A one-dimensional array (a vector) of the same type as the input, containing all of the sorted values.

If the input variable is a scalar then the variable is returned unchanged.

Arguments

None.

Keywords

COMPARE_FUNCTION

A string or Lambda function giving the name of a user-defined "compare" function. The function should have the form:

function myfunc, value1, value2

The function should return –1 if value1 should be considered "less than" value2, +1 if value1 is "greater than" value2, or 0 if the two array elements are "equal". By default, the ::Sort method uses IDL's standard rules for comparing values.

Note: If var is a pointer array, then by default the Sort method will sort the pointer identifiers, not the actual data within the pointers. However, if you pass in a compare function, then IDL will instead de-reference the pointers and pass in the actual data values to your function. In this case, your comparison function must be able to handle any data types that could be contained within your pointer array.

COUNT

Set this keyword to an integer giving the number of elements to sort. You can use this keyword to sort just the first part of an array.

INDICES

Set this keyword to a named variable. On return this variable will contain a one-dimensional integer array of subscripts that were used to sort the original values. This variable is identical to the result of calling SORT(var).

Note: If the number of elements in the input variable is smaller than the largest 32-bit integer, then INDICES will contain 32-bit integers (type LONG), otherwise INDICES will contain 64-bit integers (type LONG64).

REVERSE

Set this keyword to sort the array in reverse order.

Examples

Do a sort of a string array, but use a compare function to sort on string length. First create a function:

function string_compare, a, b

; Return -1, 0, or 1 depending upon the string length

return, (s1.Strlen()).Compare(s2.Strlen())

end

Now do the sort:

var = ['abcd', 'dcb', 'z', 'aa']

newvar = var.Sort(COMPARE_FUNCTION='string_compare')

PRINT, newvar

IDL prints:

z aa dcb abcd

Now do the same sort, but using a Lambda function:

lam = Lambda(a,b: (a.Strlen()).Compare(b.Strlen()))

newvar = var.Sort(COMPARE_FUNCTION=lam)

IDL_Variable::ToBits

The IDL_Variable::ToBits method converts the variable to an array of bits.

Example

var = [0b, 1b, 3b, 85b, 255b]

newvar = var.ToBits()

HELP, newvar

PRINT, newvar

IDL prints:

NEWVAR BYTE = Array[8, 5]

0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 1

0 0 0 0 0 0 1 1

0 1 0 1 0 1 0 1

1 1 1 1 1 1 1 1

Syntax

Result = var.ToBits( )

Return Value

For byte, integer, and floating-point data, the result is a byte array of dimensions [N, D1, D2, ...], N is the number of bits per element (either 8, 16, 32, or 64) and the [D1, D2, ...] are the dimensions of the original variable.

For string variables the result is a byte array of dimensions [8, M], where each character is converted to its extended-ASCII 8-bit representation, and M is the total number of characters within the entire string array.

Variables of type complex or type pointer will throw an error.

Note: This routine will only work with scalars or arrays up to 7 dimensions. Arrays with 8 dimensions will throw an error.

Arguments

None.

Keywords

None.

IDL_Variable::ToDouble

The IDL_Variable::ToDouble method converts the variable to the double-precision data type.

This method is equivalent to calling the DOUBLE function.

Example

var = ['3.14', '1.23', '-1d100']

newvar = var.ToDouble( )

PRINT, newvar

IDL prints:

3.1400000 1.2300000 -1.0000000e+100

Syntax

Result = var.ToDouble( )

Return Value

A scalar or array of the same dimensions as the variable.

Arguments

None.

Keywords

None.

IDL_Variable::ToInteger

The IDL_Variable::ToInteger method converts non-integer variables to type LONG (32-bit signed). Integer variables are returned unchanged.

This method is equivalent to calling the LONG function if the variable is type floating point, complex, or string.

Examples

var = ['-3.14', '1.23', '12.5']

PRINT, var.ToInteger( )

PRINT, var.ToInteger(/FLOOR)

PRINT, var.ToInteger(/CEIL)

PRINT, var.ToInteger(/ROUND)

IDL prints:

-3 1 12

-4 1 12

-3 2 13

-3 1 13

Syntax

Result = var.ToInteger( [/CEIL] [, /FLOOR] [, /ROUND] )

Return Value

A scalar or array of the same dimensions as the variable.

Arguments

None.

Keywords

Note: If no keywords are specified, the integer portion of each value is kept (for example, [12.9, -12.9] would equate to [12, -12]).

CEIL

Set this keyword to return the ceiling, or the closest integer greater than or equal to the value. This is equivalent to calling the CEIL function.

FLOOR

Set this keyword to return the floor, or the closest integer less than or equal to the value. This is equivalent to calling the FLOOR function.

ROUND

Set this keyword to round each value. This is equivalent to calling the ROUND function.

IDL_Variable::ToList

The IDL_Variable::ToList method converts the variable to a LIST. This method is equivalent to calling the LIST function with the EXTRACT keyword.

Examples

Convert a string array to a list:

IDL> var = ['My data', '3.14', '1.23', '-1d100']

IDL> newvar = var.ToList()

IDL> newvar

IDL prints:

[

"My data",

"3.14",

"1.23",

"-1d100"

]

Syntax

Result = var.ToList( /NO_COPY )

Return Value

The result is a list with the same number of elements and data types as the original variable.

Note: Because lists are one-dimensional, multidimensional arrays will be collapsed to a single dimension.

Arguments

None.

Keywords

NO_COPY

If this keyword is set then the original variable will be destoyed.

IDL_Variable::ToString

The IDL_Variable::ToString method converts the variable to type STRING with an optional format. By default, for numeric input the ::ToString method removes all extra whitespace, unless you have specified your own Format argument.

Examples

Convert a scalar number:

var = !Const.Pi

PRINT, var.ToString( )

PRINT, var.ToString("('Pi=',F7.5)")

IDL prints:

3.1415926535897931

Pi=3.14159

Convert an array of numbers:

var = [0:11]

HELP, var.ToString( )

HELP, var.ToString("(4I3)")

PRINT, var.ToString("(4I3)")

IDL prints:

<Expression> STRING = Array[12]

<Expression> STRING = Array[3]

  0  1  2   3

  4  5  6  7

  8   9 10 11

Syntax

Result = var.ToString( [Format] )

Return Value

A scalar or array of the same dimensions as the variable. If the Format argument is set then the dimensions of the result will depend upon the format string.

Arguments

Format

A formatting string. See Using Formatted Input/Output.

Keywords

None.

IDL_Variable::Uniq

The IDL_Variable::Uniq method removes all duplicate values from the input array and returns an array containing only the unique elements, sorted into increasing order.

This method is equivalent to calling var[UNIQ(var, SORT(var))].

Note: String arrays are sorted using the ASCII collating sequence. Complex arrays are sorted by their magnitude. Array values which are NaN (not-a-number) are moved to the end of the result.

Example

Construct an array of 1000 elements, containing the values 0...9. Then remove all duplicates.

var = LONG(10 * RANDOMU(seed, 1000))

PRINT, var

newvar = var.Uniq( )

PRINT, newvar

IDL prints:

4 6 6 7 3 8 4 8 3 6 5 5 6 8 3 8 1 6 6 1 ...

0 1 2 3 4 5 6 7 8 9

Syntax

Result = var.Uniq( /NO_SORT )

Return Value

A one-dimensional array (a vector) of the same type as the input, containing only the unique values.

If the input variable is a scalar then the variable is returned unchanged.

Arguments

None.

Keywords

NO_SORT

Set this keyword if the original variable is already sorted or you do not want ::Uniq to perform any sorting.

Note: The ::Uniq method works by examining neighboring values to see if they are equal, and then removing duplicates. If your original variable is not sorted, you may get unexpected results if you set NO_SORT.

Version History

8.4

Introduced

8.5

Added ::ToList method

8.8.3

Added TOLERANCE keyword to ::Equals method

See Also

Static Methods and Attributes, Variable Attributes, IDL_Integer, IDL_Number, IDL_Pointer, IDL_String, ISA, Lambda